/* Therapy Sound — Brand Kit styles */
:root{
  /* Polaroid bone — warmer than neutral, far from yellow */
  --paper: #ece6d8;
  --paper-2: #e3dcc9;
  --paper-3: #d4ccb6;
  --ink: #14110e;
  --ink-2: #221d18;
  --ink-soft: #6b6258;
  --noir: #0d0b09;
  --noir-2: #1a1612;

  /* PRIMARY — Therapy Teal, tuned to the poster halftone */
  --teal-50:  oklch(94% 0.02 200);
  --teal-100: oklch(86% 0.05 200);
  --teal-300: oklch(72% 0.10 200);   /* poster fill teal */
  --teal-500: oklch(60% 0.13 198);   /* primary UI */
  --teal-600: oklch(54% 0.13 198);   /* hover */
  --teal-700: oklch(44% 0.11 200);
  --teal-900: oklch(24% 0.06 202);

  /* SECONDARY — Rare-accent rust, only when teal has earned it */
  --rust-100: oklch(88% 0.05 38);
  --rust-300: oklch(72% 0.13 38);
  --rust-500: oklch(62% 0.16 38);    /* poster orange */
  --rust-700: oklch(48% 0.14 35);

  --rule: rgba(26,23,20,.16);
  --rule-soft: rgba(26,23,20,.08);
  --rule-dark: rgba(244,236,218,.18);
  --rule-dark-soft: rgba(244,236,218,.08);

  --f-display: 'Sora','Helvetica Neue',Helvetica,Arial,sans-serif;
  --f-serif: "Sora", "EB Garamond", Georgia, serif;
  --f-body: 'Hanken Grotesk','Helvetica Neue',Helvetica,Arial,sans-serif;
  --f-mono: 'Hanken Grotesk','Helvetica Neue',Helvetica,Arial,sans-serif;
  --f-hand: "Caveat", "Bradley Hand", "Comic Sans MS", cursive;
}

/* Grain overlay used across paper surfaces */
body::after{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.18;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--f-body);-webkit-font-smoothing:antialiased}
.page{max-width:1280px;margin:0 auto;padding:0 40px;position:relative}
.sec{padding:96px 0;border-top:1px solid var(--rule)}
.sec:first-child{border-top:none}
.eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-700);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";display:inline-block;width:22px;height:1.5px;background:var(--teal-500)}
.h-display{font-family:var(--f-display);font-weight:400;letter-spacing:-.01em;line-height:.92;font-size:clamp(56px,9vw,128px);color:var(--ink)}
.h1{font-family:var(--f-display);font-weight:400;font-size:clamp(40px,5.5vw,72px);line-height:.98;letter-spacing:-.01em;color:var(--ink)}
.h2{font-family:var(--f-display);font-weight:400;font-size:clamp(28px,3.4vw,44px);line-height:1;letter-spacing:-.005em;color:var(--ink)}
.italic{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--teal-700)}
.body{font-size:16px;line-height:1.55;color:var(--ink-2);max-width:62ch}
.lede{font-size:20px;line-height:1.5;color:var(--ink-2);max-width:60ch}
.small{font-size:13px;line-height:1.5;color:var(--ink-soft)}
.kicker{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.row{display:flex;gap:24px;align-items:flex-start}
.grid{display:grid;gap:24px}
.rule{border:0;border-top:1px solid var(--rule);margin:0}
.tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--rule);border-radius:999px;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);background:transparent}
.card{background:var(--paper-2);border:1px solid var(--rule-soft);border-radius:14px;padding:20px;color:var(--ink)}
.dot{width:8px;height:8px;border-radius:99px;background:var(--teal-500);display:inline-block}
.sticker{display:inline-block;padding:4px 10px;border-radius:99px;background:var(--teal-500);color:#fff;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}

/* Handwritten marker */
.hand{font-family:var(--f-hand);font-style:normal;font-weight:600;color:var(--teal-700);letter-spacing:.01em}
.hand-rust{color:var(--rust-700)}

/* INSET-DARK — turns any .sec into a rounded dark island on paper */
.sec.inset-dark{background:var(--noir);color:var(--paper);border-radius:24px;margin:48px 0;padding:80px 56px;border-top:0;position:relative;overflow:hidden;box-shadow:0 50px 90px -50px rgba(0,0,0,.55)}
.sec.inset-dark + .sec{border-top:0}
.sec.inset-dark::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.18;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");mix-blend-mode:screen}
.sec.inset-dark > *{position:relative;z-index:1}
.sec.inset-dark .h1,.sec.inset-dark .h2,.sec.inset-dark .h-display{color:var(--paper)}
.sec.inset-dark .lede,.sec.inset-dark .body{color:rgba(236,230,216,.78)}
.sec.inset-dark .small{color:rgba(236,230,216,.6)}
.sec.inset-dark .kicker{color:rgba(236,230,216,.55)}
.sec.inset-dark .eyebrow{color:var(--teal-300)}
.sec.inset-dark .eyebrow::before{background:var(--teal-300)}
.sec.inset-dark .italic{color:var(--teal-300)}
.sec.inset-dark .card{background:var(--noir-2);border-color:var(--rule-dark-soft);color:var(--paper)}

/* COVER */
.cover{padding:80px 0 96px;position:relative}
.cover-top{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--rule-dark-soft);padding-bottom:14px;margin-bottom:60px}
.cover-mark{position:relative;padding:40px 0 24px;display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:end}
.cover-t{width:clamp(140px,18vw,220px);height:auto;display:block;filter:drop-shadow(0 12px 36px rgba(0,0,0,.5))}
.cover-mark .h-display{position:relative;grid-column:2}
.cover-tag{grid-column:2;font-family:var(--f-serif);font-size:clamp(22px,2.6vw,32px);color:rgba(236,230,216,.85);margin:18px 0 0;letter-spacing:.01em}
.cover-tag .italic{color:var(--teal-300)}
.cover-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding-top:48px;border-top:1px solid var(--rule-dark-soft);margin-top:32px}
.cover-meta .small{margin:8px 0 0}
@media (max-width:780px){.cover-mark{grid-template-columns:1fr}.cover-mark .h-display,.cover-tag{grid-column:1}}
.dot-big{display:inline-block;width:.6em;height:.6em;background:var(--teal-500);border-radius:99px;margin-left:.05em;transform:translateY(.05em)}

/* SHARED SECTION HEADS */
.sec-head{display:grid;grid-template-columns:1fr 2fr;gap:32px;align-items:end;margin-bottom:48px}
@media (max-width:780px){.sec-head{grid-template-columns:1fr}}

/* STORY */
.story-h{margin:18px 0 32px;max-width:18ch}
.story-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.story-side{display:grid;gap:20px;padding-left:24px;border-left:1px solid var(--rule-dark-soft)}
.story-row .small{margin:6px 0 0}
@media (max-width:780px){.story-grid{grid-template-columns:1fr}.story-side{padding-left:0;border-left:0;border-top:1px solid var(--rule-dark-soft);padding-top:20px}}

/* LOGO */
.logo-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:auto auto;gap:24px;margin-top:8px}
.logo-cell{display:flex;flex-direction:column;gap:14px}
.logo-cell.big{grid-row:span 2;grid-column:1/2}
.logo-stage{background:var(--noir-2);border:1px solid var(--rule-dark-soft);border-radius:14px;padding:36px;min-height:240px;display:flex;flex-direction:column;justify-content:center;gap:14px;color:var(--paper);position:relative;overflow:hidden}
.logo-stage.center{align-items:center;justify-content:center;text-align:center}
.logo-stage.paper{background:var(--paper);color:var(--ink)}
.lk-word{font-family:var(--f-display);font-size:clamp(28px,3vw,40px);letter-spacing:-.005em;line-height:1;color:var(--paper);display:inline-flex;align-items:baseline}
.lk-word.light{color:var(--paper)}
.logo-stage.paper .lk-word{color:var(--ink)}
.dot-mid{display:inline-block;width:.32em;height:.32em;background:var(--teal-500);border-radius:99px;margin-left:.05em;transform:translateY(-.05em)}
.lk-tag{font-family:var(--f-mono);font-size:11px;letter-spacing:.32em;color:rgba(236,230,216,.6);margin-top:4px}
.logo-stage.paper .lk-tag{color:var(--ink-soft)}
.lk-tag.light{color:rgba(236,230,216,.6)}
.logo-cell.big .logo-stage{min-height:320px;justify-content:center;align-items:flex-start}
.logo-cell.big .lk-word{font-size:clamp(40px,5vw,68px)}
.logo-cell.big .lk-tag{font-size:13px;letter-spacing:.42em;margin-top:12px}
.mono-mark{display:flex;align-items:center;justify-content:center}
.t-mark{display:block;width:clamp(120px,14vw,180px);height:auto;filter:drop-shadow(0 8px 24px rgba(20,17,14,.22))}
.t-mark--paper{filter:none}
.logo-stage.dark{background:var(--noir);color:#f4ecda;background-image:radial-gradient(circle at 30% 40%, oklch(36% 0.08 200), transparent 55%),radial-gradient(circle at 70% 70%, oklch(35% 0.08 38), transparent 60%),linear-gradient(180deg,#1a1612,#0d0b09)}
.rx-stamp{display:none}
.rx-line,.rx-sig{display:none}

/* POLAROID — vintage instant-photo frame, replaces all Rx artwork */
.polaroid{background:#f7f1e3;padding:14px 14px 38px;box-shadow:0 22px 36px -18px rgba(0,0,0,.55), 0 4px 0 rgba(0,0,0,.18);border-radius:2px;position:relative;display:inline-block;color:var(--ink);transform:rotate(-2deg)}
.polaroid.r2{transform:rotate(2.5deg)}
.polaroid::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.18;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.polaroid .tape{position:absolute;top:-12px;left:50%;width:90px;height:26px;background:rgba(236,230,216,.55);transform:translateX(-50%) rotate(-3deg);border-top:1px solid rgba(20,17,14,.12);border-bottom:1px solid rgba(20,17,14,.12);box-shadow:0 2px 6px rgba(0,0,0,.18);z-index:3}
.polaroid-photo{width:220px;aspect-ratio:1/1;background:var(--noir);position:relative;overflow:hidden}
.polaroid-caption{position:absolute;left:0;right:0;bottom:8px;text-align:center;font-family:var(--f-hand);font-size:24px;color:var(--ink-2);transform:rotate(-1.5deg)}
.polaroid-caption .hand-rust{color:var(--rust-700);font-family:inherit}
.logo-rules{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule-dark-soft)}
.logo-rules .small{margin:6px 0 0}
@media (max-width:980px){.logo-grid{grid-template-columns:1fr 1fr}.logo-cell.big{grid-column:1/-1;grid-row:auto}.logo-rules{grid-template-columns:1fr}}

/* COLOR */
.kicker.light{color:#cdbf9c}
.tag.light{color:#cdbf9c;border-color:rgba(244,236,218,.25)}
.color-lede{margin:0 0 40px}
.color-hero{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px;margin-bottom:48px}
.swatch{border-radius:14px;padding:24px;min-height:260px;display:flex;flex-direction:column;justify-content:space-between}
.swatch.lg .sw-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.sw-name{font-family:var(--f-display);font-size:clamp(22px,2.4vw,30px);line-height:1;margin-top:64px}
.sw-meta{display:grid;gap:4px;margin-top:12px;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em}
.sw-meta b{font-weight:500}
.ramp{margin-bottom:32px}
.ramp .kicker{display:block;margin-bottom:10px}
.ramp-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.color .ramp:nth-of-type(3) .ramp-row{grid-template-columns:repeat(7,1fr)}
.chip{aspect-ratio:1.4/1;border-radius:10px;padding:10px;display:flex;flex-direction:column;justify-content:space-between;color:var(--ink);border:1px solid var(--rule-soft)}
.chip span{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.85}
.chip i{font-style:normal;font-family:var(--f-mono);font-size:11px;letter-spacing:.04em}
.color-usage{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;margin-top:32px}
.use .kicker{display:block;margin-bottom:14px}
.usage-bar{display:flex;height:48px;border-radius:8px;overflow:hidden;border:1px solid var(--rule-soft)}
.usage-bar span{display:block;height:100%}
.usage-legend{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-wrap:wrap;gap:18px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-2)}
.usage-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;vertical-align:middle}
.pair-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.pair{display:flex;align-items:center;gap:10px}
.pair-sw{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:18px}
@media (max-width:980px){.color-hero{grid-template-columns:1fr 1fr}.color-usage{grid-template-columns:1fr}.ramp-row,.color .ramp:nth-of-type(3) .ramp-row{grid-template-columns:repeat(3,1fr)}}

/* TYPE */
.type-row{display:grid;grid-template-columns:1fr 2fr;gap:32px;padding:28px 0;border-top:1px solid var(--rule)}
.type-row:first-of-type{border-top:0}
.type-meta .kicker{display:block;margin-bottom:8px}
.type-meta .small{margin:0 0 14px}
.type-spec{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.type-spec li{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-2);display:flex;gap:14px;border-top:1px dashed var(--rule);padding-top:6px}
.type-spec li:first-child{border-top:0;padding-top:0}
.type-spec li span{color:var(--ink-soft);min-width:80px;text-transform:uppercase;letter-spacing:.18em;font-size:10px}
.type-sample{display:grid;gap:14px;align-content:start}
.type-big{font-family:var(--f-display);font-size:clamp(48px,7vw,96px);line-height:.95;letter-spacing:-.01em;color:var(--ink)}
.type-big.serif{font-family:var(--f-display);font-weight:400}
.type-big.serif .italic{font-family:var(--f-serif);font-size:1em}
.type-mid{font-family:var(--f-display);font-size:clamp(28px,4vw,52px);line-height:1;color:var(--ink-2)}
.type-mid.serif .italic{font-family:var(--f-serif);font-size:1em}
.type-body{font-family:var(--f-body);font-size:18px;line-height:1.55;color:var(--ink-2);max-width:60ch;margin:0}
.mono-sample{font-family:var(--f-mono);color:var(--ink-2)}
.mono-line{font-family:var(--f-mono);font-size:13px;letter-spacing:.22em;color:var(--ink-soft);padding:8px 0;border-top:1px dashed var(--rule)}
.mono-line:first-child{border-top:0}
@media (max-width:780px){.type-row{grid-template-columns:1fr}}

/* VOICE */
.voice-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:32px}
.voice-col .kicker{display:block;margin-bottom:14px}
.voice-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.voice-list li{font-family:var(--f-serif);font-size:20px;line-height:1.3;color:var(--ink-2);padding-bottom:10px;border-bottom:1px dashed var(--rule)}
.voice-list li:last-child{border-bottom:0}
.voice-list.nope li{color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--rust-500);text-decoration-thickness:1px}
.voice-list.nope li i{color:var(--ink-2)}
.quote{font-family:var(--f-display);font-size:28px;line-height:1.05;letter-spacing:-.005em;padding:18px 0;border-top:1px solid var(--rule);color:var(--ink)}
.quote:first-of-type{border-top:0;padding-top:0}
.quote .italic{font-size:1em;color:var(--teal-700)}
@media (max-width:980px){.voice-grid{grid-template-columns:1fr}}

/* COMPONENTS */
.comp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.comp{display:flex;flex-direction:column;gap:14px;min-height:240px}
.comp .kicker{display:block}
.span-2{grid-column:span 2}
/* BUTTONS — more vibrant, more weight */
.btn{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;border:1.5px solid transparent;border-radius:999px;padding:14px 24px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;font-weight:500;transition:transform .15s ease, box-shadow .2s ease, background .15s ease;line-height:1}
.btn .spark{display:inline-block;color:inherit;font-size:14px;line-height:1}
.btn-primary{background:var(--teal-500);color:#fff;box-shadow:0 4px 0 var(--teal-700), 0 14px 28px -10px oklch(56% 0.16 198 / .55)}
.btn-primary:hover{background:var(--teal-600);transform:translateY(-1px);box-shadow:0 5px 0 var(--teal-700), 0 18px 32px -10px oklch(56% 0.16 198 / .6)}
.btn-primary:active{transform:translateY(2px);box-shadow:0 2px 0 var(--teal-700), 0 8px 16px -10px oklch(56% 0.16 198 / .4)}
.btn-rust{background:var(--rust-500);color:#1a0f08;box-shadow:0 4px 0 var(--rust-700), 0 14px 28px -10px oklch(62% 0.18 38 / .55)}
.btn-rust:hover{background:var(--rust-300)}
.btn-dark{background:var(--noir);color:var(--paper);box-shadow:0 4px 0 #000, inset 0 0 0 1px rgba(244,236,218,.06)}
.btn-dark:hover{background:#000}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-link{background:transparent;color:var(--teal-700);border:0;padding:8px 0;border-bottom:1.5px solid var(--teal-500);border-radius:0;letter-spacing:.18em;box-shadow:none}
.btn-link:hover{color:var(--teal-500)}
.btn.sm{padding:11px 18px;font-size:11px}
.btn.block{width:100%;justify-content:center;padding:16px}
.btn-stack,.tag-stack,.dj-stack{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.dj-stack{flex-direction:column;align-items:stretch}
.dates{display:flex;gap:10px;flex-wrap:wrap}
.date-chip{border:1px solid var(--rule);border-radius:12px;padding:10px 12px;background:var(--paper);position:relative;min-width:78px;display:flex;flex-direction:column;align-items:center;color:var(--ink)}
.date-chip i{font-style:normal;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-soft)}
.date-chip b{font-family:var(--f-display);font-size:30px;line-height:1;margin:6px 0 2px;color:var(--ink)}
.date-chip u{text-decoration:none;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-soft)}
.date-chip.active{background:var(--teal-50);border-color:var(--teal-500)}
.date-chip.active i,.date-chip.active u{color:var(--teal-700)}
.date-chip .chip-flag{display:block;margin-top:8px;font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;background:var(--teal-500);color:#fff;padding:3px 8px;border-radius:99px}
.date-chip .chip-lock{display:block;margin-top:8px;font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--rule);padding:3px 8px;border-radius:99px;color:var(--ink-soft)}

/* Session card */
.session-card{display:grid;grid-template-columns:160px 1fr;gap:18px;background:var(--paper);border:1px solid var(--rule-soft);border-radius:12px;padding:14px;color:var(--ink)}
.sc-poster{position:relative;aspect-ratio:.7/1;border-radius:6px;overflow:hidden;background:#0a0908}
.sc-poster-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 30% 30%, var(--teal-700), transparent 55%),
  radial-gradient(circle at 70% 60%, var(--rust-500), transparent 50%),
  linear-gradient(180deg,#1c1916,#0e0c0a);
  filter:contrast(1.05) saturate(.9);
  opacity:.85}
.sc-poster-fg{position:absolute;inset:0;padding:10px;color:#efe7d6;font-family:var(--f-mono);display:flex;flex-direction:column}
.sc-pmeta{font-size:7px;letter-spacing:.22em;display:flex;justify-content:space-between;color:#cdbf9c}
.sc-pmeta em{font-style:normal}
.sc-ptitle{font-family:var(--f-display);font-size:18px;line-height:.95;margin-top:8px;letter-spacing:-.01em}
.sc-ptitle span{font-size:9px;font-family:var(--f-mono);letter-spacing:.22em;display:inline-block;margin-top:6px;color:var(--teal-300)}
.sc-pname{margin-top:auto;font-family:var(--f-display);font-size:16px;line-height:1}
.sc-pbadge{position:absolute;top:10px;right:10px;width:18px;height:18px;border-radius:99px;background:#efe7d6;color:#161310;font-family:var(--f-display);font-size:11px;display:flex;align-items:center;justify-content:center}
.sc-body{display:flex;flex-direction:column;gap:6px;padding:6px 4px}
.sc-title{font-family:var(--f-display);font-size:24px;line-height:1;color:var(--ink)}
.sc-line{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase}
.sc-line em{color:var(--teal-700);font-style:normal}
.sc-actions{margin-top:auto;display:flex;align-items:center;gap:14px}

/* DJ chip */
.dj-row{display:flex;align-items:center;gap:12px;padding:10px;border:1px solid var(--rule-soft);border-radius:10px;background:var(--paper)}
.dj-avatar{width:36px;height:36px;border-radius:99px;flex:none}
.dj-row b{font-family:var(--f-display);font-size:14px;letter-spacing:.04em;display:block;color:var(--ink)}
.dj-row .small{display:block;margin-top:2px;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase}

/* Form — high-contrast on cream paper */
.form-demo{display:grid;gap:14px}
.form-demo label{display:grid;gap:6px}
.form-demo .kicker{margin-bottom:0;color:var(--ink-2);font-weight:500}
.form-demo input,.form-demo select{font-family:var(--f-body);font-size:15px;font-weight:500;padding:14px;border:1.5px solid var(--ink);border-radius:10px;background:#f7f1e3;color:var(--ink);box-shadow:inset 0 -2px 0 rgba(20,17,14,.08);transition:background .15s ease, border-color .15s ease, box-shadow .15s ease}
.form-demo input::placeholder{color:var(--ink-soft)}
.form-demo input:hover,.form-demo select:hover{background:#fff}
.form-demo input:focus,.form-demo select:focus{outline:none;background:#fff;border-color:var(--teal-500);box-shadow:0 0 0 3px oklch(60% 0.13 198 / .25), inset 0 -2px 0 var(--teal-500)}
.form-demo select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink) 50%),linear-gradient(-45deg,transparent 50%,var(--ink) 50%);background-position:calc(100% - 18px) 50%, calc(100% - 12px) 50%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px}

@media (max-width:980px){.comp-grid{grid-template-columns:1fr 1fr}.span-2{grid-column:span 2}}
@media (max-width:680px){.comp-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.session-card{grid-template-columns:1fr}.sc-poster{aspect-ratio:1.4/1}}

/* POSTERS */
.poster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.poster{position:relative;aspect-ratio:.72/1;border-radius:6px;overflow:hidden;padding:24px;display:flex;flex-direction:column;justify-content:space-between;margin:0}
.p-paper{background:var(--paper-2);border:1px solid var(--rule-soft);color:var(--ink)}
.p-corner-mark{position:absolute;top:14px;right:14px;width:34px;height:auto;z-index:3}
.p-corner-mark img{width:100%;height:auto;display:block}
.p-photo{background:#161310;color:#efe7d6}
.p-teal{background:var(--teal-700);color:var(--paper)}
.p-corner{position:absolute;top:14px;right:18px;font-family:var(--f-serif);font-style:italic;font-size:28px;color:var(--teal-700)}
.p-top{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--rule);padding-bottom:8px}
.p-top.light{border-bottom-color:rgba(244,236,218,.25)}
.p-kicker{font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.p-top.light .p-kicker,.p-footer.light .p-kicker{color:rgba(244,236,218,.7)}
.p-title{font-family:var(--f-display);font-size:clamp(28px,3.2vw,42px);line-height:.92;letter-spacing:-.01em;margin:16px 0}
.p-title.light{color:#efe7d6}
.p-title .italic{font-family:var(--f-serif);font-size:1em;color:var(--teal-700)}
.p-title .italic.teal-soft{color:var(--teal-300)}
.p-title .italic.paper-soft{color:var(--paper)}
.p-byline{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;line-height:1.6;color:var(--ink-soft);text-transform:uppercase}
.p-footer{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--rule);padding-top:10px;margin-top:auto}
.p-footer.light{border-top-color:rgba(244,236,218,.25)}
.p-stamp{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;color:var(--ink-soft);line-height:1.6;text-transform:uppercase}
.p-dot{width:18px;height:18px;border-radius:99px;background:var(--teal-500)}
/* photo poster */
.p-photo-bg{position:absolute;inset:0;background:#0e0c0a}
.ph-stripes{position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(244,236,218,.04) 0 6px,transparent 6px 12px),radial-gradient(circle at 60% 40%, oklch(35% 0.08 200), transparent 60%),linear-gradient(180deg,#0e0c0a,#1c1916)}
.ph-label{position:absolute;left:14px;bottom:14px;font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;color:rgba(244,236,218,.4);text-transform:uppercase}
.p-photo-fg{position:relative;z-index:1;display:flex;flex-direction:column;height:100%;mix-blend-mode:normal}
.p-photo .p-title{color:#efe7d6}
.p-name{font-family:var(--f-display);font-size:clamp(20px,2.4vw,30px);line-height:.95;color:var(--teal-300);margin-top:auto;margin-bottom:14px}
/* teal poster */
.p-teal .p-top{border-bottom-color:rgba(244,236,218,.25)}
.p-teal .p-title{color:var(--paper)}
.p-strip{display:flex;gap:10px;align-items:center;font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;color:rgba(244,236,218,.7);margin-bottom:auto}
.poster-rules{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.poster-rules .small{margin:6px 0 0}
@media (max-width:980px){.poster-grid{grid-template-columns:1fr 1fr}.poster-rules{grid-template-columns:1fr}}
@media (max-width:680px){.poster-grid{grid-template-columns:1fr}}

/* APPLIED */
.apply-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:32px;align-items:start}
.apply-phone .kicker{display:block;margin-bottom:12px}
.phone{background:#161310;border-radius:24px;padding:14px;color:#efe7d6;max-width:420px;box-shadow:0 30px 60px -30px rgba(0,0,0,.4)}
.phone-bar{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;color:rgba(244,236,218,.5);padding:4px 6px 10px}
.phone-nav{background:var(--paper);border-radius:14px;padding:14px;text-align:center;color:var(--ink)}
.lk-word.sm{font-size:18px;letter-spacing:-.005em;display:inline-flex;align-items:baseline}
.lk-tag.sm{font-size:9px;letter-spacing:.32em;color:var(--ink-soft);display:block;margin-top:2px}
.phone-tabs{display:flex;justify-content:center;gap:6px;margin-top:10px;flex-wrap:wrap}
.pill{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;padding:6px 10px;border-radius:99px;color:var(--ink-soft);background:transparent}
.pill.active{background:var(--teal-500);color:#fff}
.phone-hero{margin-top:14px;background:linear-gradient(160deg,#1c1916,#0e0c0a);border-radius:14px;padding:18px;position:relative;overflow:hidden}
.phone-hero::before{content:"";position:absolute;width:240px;height:240px;border-radius:99px;background:radial-gradient(circle, var(--teal-700), transparent 70%);top:-100px;right:-100px;opacity:.6}
.ph-card{position:relative}
.ph-title{font-family:var(--f-display);font-size:34px;line-height:.95;margin:8px 0}
.ph-title .italic{font-family:var(--f-serif);color:var(--teal-300);font-size:1em}
.ph-body{font-size:13px;color:rgba(244,236,218,.7);line-height:1.5;margin:0 0 14px}
.phone-section{margin-top:14px;background:var(--paper);border-radius:14px;padding:18px;color:var(--ink);position:relative}
.phone-section::before{content:"";position:absolute;inset:0;border-radius:14px;pointer-events:none;mix-blend-mode:multiply;opacity:.15;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.phone-section > *{position:relative}
.phone-section .kicker{display:block;margin-bottom:6px}
.ph-h{font-family:var(--f-display);font-size:28px;line-height:1;margin:0 0 14px}
.ph-h .italic{font-family:var(--f-serif);color:var(--teal-700);font-size:1em}
.dates.inline{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}
.date-chip.sm{min-width:64px;padding:8px}
.date-chip.sm b{font-size:22px}

.apply-side{display:grid;gap:20px}
.apply-card{display:flex;flex-direction:column;gap:14px}
.merch.tee{aspect-ratio:1.2/1;background:linear-gradient(180deg,var(--paper-3),var(--paper-2));border-radius:10px;position:relative;display:flex;align-items:center;justify-content:center}
.tee-body{width:62%;height:62%;background:var(--paper);border-radius:8px;display:flex;align-items:center;justify-content:center;clip-path:polygon(0 14%,18% 0,38% 0,50% 8%,62% 0,82% 0,100% 14%,90% 28%,90% 100%,10% 100%,10% 28%)}
.tee-polaroid{background:#f7f1e3;padding:8px 8px 24px;position:relative;transform:rotate(-3deg);box-shadow:0 8px 16px -8px rgba(0,0,0,.4)}
.tee-polaroid .tape{position:absolute;top:-8px;left:50%;width:48px;height:14px;background:rgba(236,230,216,.6);transform:translateX(-50%) rotate(-3deg);border-top:1px solid rgba(20,17,14,.12);border-bottom:1px solid rgba(20,17,14,.12)}
.tee-photo{width:80px;aspect-ratio:1/1;background:var(--noir);display:flex;align-items:center;justify-content:center}
.tee-photo img{width:60%;height:auto}
.tee-caption{position:absolute;left:0;right:0;bottom:4px;text-align:center;font-family:var(--f-hand);font-size:14px;color:var(--ink-2)}
.small-stamp{display:none}

.social{aspect-ratio:1/1;background:#161310;color:var(--paper);border-radius:10px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.social::before{content:"";position:absolute;width:200px;height:200px;border-radius:99px;background:radial-gradient(circle,var(--teal-700),transparent 70%);top:-60px;right:-60px;opacity:.7}
.soc-top{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,236,218,.5);position:relative}
.soc-title{font-family:var(--f-display);font-size:clamp(28px,4vw,44px);line-height:.95;position:relative}
.soc-title .italic{font-family:var(--f-serif);color:var(--teal-300);font-size:1em}
.soc-bot{display:flex;justify-content:space-between;align-items:center;position:relative;gap:10px;flex-wrap:wrap}

.ticket{display:grid;grid-template-columns:1fr 14px 1fr;background:var(--paper);border:1px solid var(--rule);border-radius:10px;overflow:hidden;min-height:160px}
.t-left,.t-right{padding:16px;display:flex;flex-direction:column;gap:8px}
.t-right{align-items:flex-end;text-align:right;background:var(--ink);color:var(--paper)}
.t-right .kicker{color:rgba(244,236,218,.6)}
.t-title{font-family:var(--f-display);font-size:28px;line-height:.95}
.t-num{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em}
.t-dot{width:14px;height:14px;border-radius:99px;background:var(--teal-500);margin-top:auto}
.t-perf{background:repeating-linear-gradient(180deg,var(--rule) 0 4px,transparent 4px 8px)}

@media (max-width:980px){.apply-grid{grid-template-columns:1fr}}

/* FOOTER */
.foot{padding:48px 0 80px;border-top:1px solid var(--rule)}
.foot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:14px}
.foot-note{margin:0;max-width:72ch;color:var(--ink-2)}
.foot-note a{color:var(--teal-700)}

/* =================================================================
   FEED — IG-style island (use as .sec.feed.inset-dark)
   ================================================================= */
.feed{position:relative;overflow:hidden}
.feed::before{content:"";position:absolute;inset:0;background-image:
  radial-gradient(circle at 20% 10%, oklch(38% 0.10 198 / .35), transparent 45%),
  radial-gradient(circle at 85% 90%, oklch(38% 0.10 38 / .22), transparent 50%),
  url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='3' height='3'><circle cx='1' cy='1' r='.6' fill='%23ffffff' opacity='.04'/></svg>");
  pointer-events:none}
.feed > *{position:relative}
.feed-lede b{color:var(--rust-300);font-weight:500}

.ig{background:var(--noir-2);border:1px solid var(--rule-dark);border-radius:16px;padding:24px;box-shadow:0 40px 80px -40px #000}
.ig-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--rule-dark-soft);margin-bottom:24px;flex-wrap:wrap;gap:18px}
.ig-handle{display:flex;align-items:center;gap:14px}
.ig-handle img{width:56px;height:56px;border-radius:99px;background:var(--noir);padding:6px;border:1px solid var(--rule-dark)}
.ig-handle b{font-family:var(--f-display);font-size:16px;letter-spacing:.02em;display:block;color:var(--paper)}
.ig-handle .small{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;color:rgba(244,236,218,.55);margin-top:4px;text-transform:none}
.ig-stats{display:flex;gap:28px;font-family:var(--f-mono)}
.ig-stats b{font-family:var(--f-display);font-size:18px;color:var(--paper);display:block}
.ig-stats span{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,236,218,.5);display:block;margin-top:2px}

.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.ig-tile{position:relative;aspect-ratio:1/1;background:var(--noir);overflow:hidden;color:var(--paper);margin:0;display:flex;flex-direction:column;padding:14px;font-family:var(--f-display);isolation:isolate}
.ig-tile .ig-t{position:absolute;top:10px;right:10px;width:32px;height:32px;z-index:5;display:flex;align-items:center;justify-content:center}
.ig-tile .ig-t img{width:100%;height:auto;display:block}
.ig-tile .kicker.light{color:rgba(244,236,218,.65)}

/* Poster tile: triangles (Anton / May 14) */
.tile-tri{background:
  radial-gradient(circle at 30% 30%, oklch(28% 0.07 200), transparent 60%),
  linear-gradient(180deg, #14110e, #0a0908);
  background-color:#0a0908}
.tile-tri::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='4'><circle cx='2' cy='2' r='.7' fill='%23000' opacity='.45'/></svg>");pointer-events:none;mix-blend-mode:multiply;z-index:1}
.tile-tri > *{position:relative;z-index:2}
.tile-head{display:flex;flex-direction:column;gap:2px}
.th-title{font-family:var(--f-display);font-size:clamp(18px,2.4vw,30px);line-height:.92;color:var(--paper);letter-spacing:-.005em}
.th-title.small{font-size:clamp(16px,2vw,24px)}
.th-title.rust{color:var(--rust-500)}
.th-date{font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;color:var(--rust-500);margin-top:6px}
.tri-stage{position:absolute;inset:0;display:grid;place-items:center;z-index:1;pointer-events:none}
.tri-stage .tri{position:absolute;width:0;height:0}
.tri-1{border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:96px solid var(--teal-700);top:24%;left:22%;opacity:.95}
.tri-2{border-left:42px solid transparent;border-right:42px solid transparent;border-top:70px solid var(--rust-700);top:54%;left:32%}
.tri-3{border-left:42px solid transparent;border-right:42px solid transparent;border-top:70px solid var(--teal-500);top:52%;left:38%;mix-blend-mode:screen;opacity:.85}
.tri-4{border-left:24px solid transparent;border-right:24px solid transparent;border-bottom:40px solid var(--rust-500);top:32%;left:46%;mix-blend-mode:screen;opacity:.8}
.tile-name{margin-top:auto;font-family:var(--f-display);font-size:clamp(16px,2.2vw,26px);line-height:.95;color:var(--paper);position:relative;z-index:3}
.tile-name em{font-style:normal;color:var(--rust-300);font-size:.7em;display:block;margin-top:4px;letter-spacing:.02em}
.tile-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;position:relative;z-index:3}

/* Photo tile */
.tile-photo{padding:0}
.ph-shot{position:absolute;inset:0;background:
  radial-gradient(ellipse at 50% 40%, oklch(45% 0.10 200), transparent 55%),
  radial-gradient(ellipse at 30% 90%, oklch(22% 0.04 200), transparent 60%),
  linear-gradient(180deg, oklch(20% 0.03 200), oklch(8% 0.01 200));
  z-index:0}
.ph-shot::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(90deg, transparent 0 8px, rgba(0,0,0,.18) 8px 9px),
  radial-gradient(circle at 50% 30%, oklch(70% 0.12 200 / .35), transparent 40%);
  mix-blend-mode:overlay}
.ph-shot::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='3' height='3'><circle cx='1.5' cy='1.5' r='.6' fill='%23000' opacity='.4'/></svg>");mix-blend-mode:multiply}
.ph-shot.warm{background:
  radial-gradient(ellipse at 60% 50%, oklch(55% 0.16 38), transparent 55%),
  radial-gradient(ellipse at 20% 80%, oklch(28% 0.05 38), transparent 60%),
  linear-gradient(180deg, oklch(20% 0.04 38), oklch(8% 0.02 38))}
.ph-shot.warm::before{background:
  repeating-linear-gradient(90deg, transparent 0 8px, rgba(0,0,0,.2) 8px 9px),
  radial-gradient(circle at 60% 40%, oklch(70% 0.16 38 / .35), transparent 40%)}
.ph-shot.disco{background:
  radial-gradient(circle at 50% 30%, oklch(70% 0.18 200), transparent 25%),
  radial-gradient(circle at 30% 60%, oklch(60% 0.14 200), transparent 30%),
  radial-gradient(circle at 70% 70%, oklch(55% 0.14 38), transparent 30%),
  linear-gradient(180deg, oklch(15% 0.03 200), oklch(8% 0.02 200))}
.photo-cap{position:absolute;left:14px;bottom:12px;z-index:4}

/* Stripes tile (the big "A DOSE OF HOUSE" poster) */
.tile-stripes{background:#0a0908;padding:14px 14px 16px}
.tile-stripes::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='4'><circle cx='2' cy='2' r='.7' fill='%23000' opacity='.5'/></svg>");pointer-events:none;mix-blend-mode:multiply;z-index:1}
.tile-stripes > *{position:relative;z-index:2}
.th-stack{display:flex;flex-direction:column;gap:2px}
.th-stack.tight{gap:1px}
.th-sub{font-family:var(--f-display);font-size:11px;letter-spacing:.18em;color:var(--teal-300);background:var(--teal-700);display:inline-block;padding:4px 8px;margin-top:6px;align-self:flex-start;color:var(--paper)}
.stripes{position:absolute;inset:auto 14px 32% 14px;display:flex;flex-direction:column;gap:4px;z-index:1}
.stripes span{height:6px;background:var(--rust-500);transform:skewY(-12deg);transform-origin:left}
.stripes span:nth-child(2){background:var(--teal-300);width:80%}
.stripes span:nth-child(3){background:var(--rust-500);width:90%}
.stripes span:nth-child(4){background:var(--teal-700);width:70%}
.tile-names{font-family:var(--f-display);font-size:clamp(13px,1.5vw,18px);line-height:1.05;color:var(--paper);margin-top:auto;position:relative;z-index:3}
.tile-names em{font-style:normal;color:var(--rust-300)}
.tile-names.xs{font-size:clamp(11px,1.3vw,15px)}
.hg-stamp{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:6px;border-top:1px solid var(--rule-dark-soft);position:relative;z-index:3}

/* Bar tile */
.tile-bars{background:#0a0908}
.tile-bars::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='4'><circle cx='2' cy='2' r='.7' fill='%23000' opacity='.45'/></svg>");pointer-events:none;mix-blend-mode:multiply;z-index:1}
.tile-bars > *{position:relative;z-index:2}
.bars{position:absolute;inset:30% 14px 28% 50%;display:flex;flex-direction:column;gap:3px;z-index:1}
.bars span{height:9px;background:var(--teal-500)}
.bars span:nth-child(1){width:90%;background:var(--rust-500)}
.bars span:nth-child(2){width:60%;background:var(--paper-3)}
.bars span:nth-child(3){width:80%;background:var(--teal-500)}
.bars span:nth-child(4){width:50%;background:var(--rust-500)}
.bars span:nth-child(5){width:75%;background:var(--teal-300)}
.bars span:nth-child(6){width:40%;background:var(--paper-3)}
.bars-date{font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;color:var(--paper);margin-top:auto;display:flex;align-items:center;gap:6px;position:relative;z-index:3}
.bars-date em{font-style:normal;color:var(--rust-500)}

.feed-notes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:28px;padding-top:24px;border-top:1px solid var(--rule-dark-soft)}
.feed-notes .kicker{color:var(--teal-300);display:block;margin-bottom:6px}
.feed-notes .small{color:rgba(244,236,218,.7);margin:0}
.feed-notes .small i{color:var(--rust-300);font-style:italic}
@media (max-width:780px){.ig-grid{grid-template-columns:repeat(2,1fr)}.feed-notes{grid-template-columns:1fr}}

/* "tiny" helper for the rare-accent note in color section */
.tiny{font-size:9px;letter-spacing:.18em;opacity:.7}
